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A PARALLEL COUNTER AND A MULTIPLICATION LOGIC CIRCUIT 

The present invention generally relates to digital electronic devices and more 
particularly to a digital electronic device performing binary logic. In one aspect the 
present invention relates to a parallel counter and in another aspect the present invention 
relates to a multiplication logic circuit for multiplying two binary numbers. 

It is instrumental for many applications to have a block that adds n inputs together. An 
output of this block is a binary representation of the number of high inputs. Such blocks, 
called parallel counters (L. Dadda, Some Schemes for Parallel Multipliers, Alta Freq 34: 
349-356 (1965); E. E. Swartzlander Jr., Parallel Counters, IEEE Trans. Comput. C-22: 
1021-1024 (1973)), are used in circuits performing binary multiplication. There are 
other applications of a parallel counter, for instance, majority-voting decoders or RSA 
encoders and decoders. It is important to have an implementation of a parallel counter 
that achieves a maximal speed. It is known tousfe parallel counters in multiplication (L. 
Dadda, On Parallel Digital Multipliers, Alta Freq 45: 574-580 (1976)). 

A full adder is a special parallel counter with a three-bit input and a two-bit output. A 
current implementation of higher parallel counters i.e. with a bigger number of inputs is 
based on using full adders (C. C. Foster and F. D. Stockton, Counting Responders in an 
Associative Memory, IEEE Trans. Comput. C-20: 1580-1583 (1971)). In general, the 
least significant bit of an output is the fastest bit to produce in such implementation 
while other bits are usually slower. 

The following notation is used for logical operations: 

0 - Exclusive OR; 



v-OR; 



a - AND; 



-i - NOT. 




An efficient prior art design (Foster and Stockton) of a parallel counter uses full adders. 
A full adder, denoted FA, is a three-bit input parallel counter shown in figure 1 - It has 
three inputs Xw X2, X3, and two outputs S and C. Logical expressions for outputs are 

S ~ X]©X2©X3, 

C = (XiaX 2 )v(X i aX 3 )v(X2aX 3 ). 
A half adder, denoted HA, is a two bit input parallel counter shown in figure 1 . It has 
two inputs Xi, X2 and two outputs S and C. Logical expressions for outputs are 

S ~ Xi©X2, 

C = X1AX2. 

A prior art implementation of a seven-bit input parallel counter illustrated in figure 2. 

Multiplication is a fundamental operation. Given two n-digit binary numbers 
A n - 1 2 n ' l +A n .22 n " 2 +...+A|2+A 0 and B n _,2 n " 1 +B n _ 2 2 n - 2 +...+B 1 2+Bo, 
their product 

P 2(Vl 2 2n - 1 +P 2 n-22 2n ' 2 +. . .+P,2+P 0 
may have up to 2n digits. Logical circuits generating all Pi as outputs generally follow 
the scheme in figure 14. Wallace has invented the first fast architecture for a multiplier, 
now called the Wallace-tree multiplier (Wallace, C. S., A Suggestion for a fast 
Multiplier, IEEE Trans. Electron. Comput. EC-13: 14-17 (1964)). Dadda has 
investigated bit behaviour in a multiplier (L. Dadda, Some Schemes for Parallel 
Multipliers, Alta Freq 34: 349-356 (1965)). He has constructed a variety of multipliers 
and most multipliers follow Dadda's scheme. 

Dadda' s multiplier uses the scheme in on figure 22. If inputs have 8 bits then 64 parallel 
AND gates generate an array shown in figure 23, The AND gate sign a is omitted for 
clarity so that Ai aBj becomes AjBj. The rest of figure 23 illustrates array reduction that 
involves full adders (FA) and half adders (HA), Bits from the same column are added by 
half adders or full adders. Some groups of bits fed into a full adder are in rectangles. 
Some groups of bits fed into a half adder are in ovals. The result of array reduction is 
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just two binary numbers to be added at the last step. One adds these two numbers by one 
of the fast addition schemes, for instance* conditional adder or cany-look-ahead adder. 

ice wit h. the first aspect the present invention provides a parallel counter 
based on algebraic pmpnlTPs rt Tyminrtn"' IfTrrfHHre, Fach rt f The plu rality of binary 
output bits is generated as a symmetric function of a plurality of binary input bits. 

The symmetric functions comprise logically AND combining sets of one or more binary 
inputs and logically OR or exclusive OR logic combining the logically combined sets of 
binary inputs to generate a binary output. The OR and the exclusive OR symmetric 
functions are elementary symmetric functions and the generated output binary bit 
depends only on the number of high inputs among the input binary bits. For the OR 
symmetric function, if the number of high inputs is m, the output is high if and only if m 
>k, where k is the size of the sets of binary inputs. Similarly, the generated output 
binary bit using the exclusive OR symmetric function is high if and only if m >k and the 
number of subsets of inputs of the set of high inputs is an odd number. In one 
embodiment the size of the sets can be selected. The i th output bit can be generated 
using the symmetric function using exclusive OR logic by selecting the set sizes to be of 
size 2\ where i is an integer from 1 to N, N is the number of binary outputs, and i 
represents the significance of each binary output. 

In one embodiment the sets of binary inputs used in the symmetric functions are each 
unique and they cover all possible combinations of binary inputs. 

This embodiment reduces the amount of fan-out in the circuit and increases the amount 
of logic sharing. It thus makes parallel counters for a large binary number more 
practicable. 



In another embodiment of the present invention, the logic and inputs of the parallel 
counter are divided in accordance with a binary tree. The logic circuit is divided into a 
plurality of logic units. Each logic unit is arranged to generate logic unit binary outputs 




as a symmetric function of the binary inputs to the logic unit The binary inputs are 
divided into inputs into the plurality of logic units, and the binary outputs of the 
plurality of outputs are generated using binary outputs of a plurality of the logic units. 

In a preferred embodiment, each of the logic units is arranged to receive 2" of the binary 
inputs, where n is an integer indicating the level of the logic units in the binary tree* the 
logic circuit has m logic units at each leveL where m is a rounded up integer determined 
from (the number of binary inputs)/ 2 n , logic units having a higher level in the binary 
tree comprise logic of logic units at lower levels in the binary tree, and each logic unit is 
arranged to generate logic unit binary outputs as a symmetric function of the binary 
inputs to the logic unit. 

In one embodiment, each logic unit at the first level is arranged to generate logic unit 
binary outputs as a smallest elementary symmetric function of the binary inputs to said 
logic circuit. 

In one; embodiment, each logic unit at the first level is arranged to generate logic unit 
binary outputs as a symmetric function of the binary inputs to the logic circuit using OR 
logic for combining the binary inputs. 

In one embodiment, each logic unit at the first level is arranged to logically AND each 
of the binary inputs to the logic unit and to logically OR each of the binary inputs to the 
logic unit to generate the logic unit binary outputs. 

In one embodiment, each logic unit at the first level is arranged to generate logic unit 
binary outputs as a symmetric function of the binary inputs to the logic circuit using 
exclusive OR logic for combining the binary inputs. 

In one embodiment, each logic unit at the first level is arranged to logically AND each 
of the binary inputs to the logic unit and to logically exclusively OR each of the binary 
inputs to the logic unit to generate the logic unit binary outputs. 
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In one embodiment, elementary logic units are provided as the logic units at the first 
level for performing elementary symmetric functions, outputs from each of two primary 
elementary logic units receiving four logically adjacent binary inputs from said plurality 
of inputs are input to two secondary elementary logic units, an output from each of the 
secondary elementary logic units is input to a tertiary elementary logic unit, and the 
primary, secondary and tertiary elementary logic units form a secondary logic unit at a 
second level of the binary tree having a binary output comprising a binary output from 
each of the secondary elementary logic units and two binary outputs from the tertiary 
elementary logic unit. 

In one embodiment, tertiary logic units at a third level of the binary tree each comprise 
two secondary logic units receiving eight logically adjacent binary inputs from the 
plurality of inputs, four elementary logic units receiving as inputs the outputs of the two 
secondary logic units, and further logic for generating binary outputs as a symmetric 
function of the binary inputs to the tertiary logic unit using the binary outputs of the four 
elementary logic units. 

In one embodiment, quaternary logic units at a fourth level of the binary tree each 
comprise two tertiary logic units receiving sixteen logically adjacent binary inputs from 
the plurality of inputs, four elementary logic units receiving as inputs the outputs of the 
two tertiary logic units, and further logic for generating binary outputs as a symmetric 
function of the binary inputs to the quaternary logic unit using the binary outputs of the 
four elementary logic units. 

In one embodiment, elementary logic units are provided as the logic units at the first 
level for performing the smallest elementary symmetric functions, and logic units for 
higher levels comprise logic units of lower levels. 

In one embodiment, the logic units for higher levels above the second level comprise 
logic units of an immediately preceding level and elementary logic units 
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In one embodiment, each logic unit at each level is arranged to generate logic unit 
binary outputs as a symmetric function of the binary inputs to the logic circuit using OR 
logic for combining the binary inputs. 

In one embodiment, each logic unit at each level is arranged to generate logic unit 
binary outputs as a symmetric function of the binary inputs to the logic circuit using 
exclusive OR logic for combining the binary inputs. 

In one embodiment of the present invention, each of the binary outputs can be generated 
using a symmetric function which uses exclusive OR logic. However, exclusive OR 
logic is not as fast as OR logic. 

In accordance with another embodiment of the present invention at least one of the 
binary outputs is generated as a symmetric function of the binary inputs using OR logic 
for combining a variety of sets of one or more binary inputs. The logic is arranged to 
logically AND members of each set of binary inputs and logically OR the result of the 
AND operations. 

Thus use of the symmetric function using OR logic is faster and can be used for 
generation of the most significant output bit. In such an embodiment the set size is set 
to be 2 N-1 , where N is the number of binary outputs and the N* binary output is the most 
significant. 

It is also possible to use the symmetric function using OR logic for less significant bits 
on the basis of the output value of a more significant bit In such a case, a plurality of 
possible binary outputs for a binary output less significant than the N lh are generated as 
symmetric functions of the binary inputs using OR logic for combining a plurality of 
sets of one or more binary inputs, where N is the number of binary outputs. Selector 
logic is provided to select one of the possible binary outputs based on a more significant 
binary output value. The si2e of the sets used in such an arrangement for the (N-!)* bit 



is preferably 2 N * 1 + 2 n * 2 and 2 N ~ 2 respectively and one of the possible binary outputs is 
selected based on the binary output value. 

In one embodiment of the present invention the circuit is designed in a modular form. A 
plurality of subcircuit logic modules are designed, each for generating intermediate 
binary outputs as a symmetric function of some of the binary inputs. Logic is also 
provided in this embodiment for logically combining the intermediate binary outputs to 
generate a binary outputs. 

Since OR logic is faster, in a preferred embodiment the subcircuit logic modules 
implement the symmetric functions using OR logic. In one embodiment the subcircuit 
modules can be used for generating some binary outputs and one or more logic modules 
can be provided for generating other binary outputs in which each logic module 
generates a binary output as a symmetric function of the binary inputs exclusive OR 
logic for combining a plurality of sets of one or more binary inputs. 

Another aspect of the present invention provides a method of designing a logic circuit 
comprising: providing a library of logic module designs each for performing a small 
symmetric function; designing a logic circuit to perform a large symmetric function; 
identifying small symmetric functions which can perform said symmetric function; 
selecting logic modules from said library to perform said small symmetric functions; 
identifying a logic circuit in the selected logic circuit which performs a symmetric 
function and which can be used to perform another symmetric function; selecting the 
logic circuit corresponding to the identified symmetric function and using the selected 
logic circuit with inverters to perform said other symmetric function using the 
relationship between the symmetric functions: 

OR_n_k(X|...X n ) = ^OR_nJn+l-k)(-iX,„,-<Xn) 
where denotes an inversion, n is the number of inputs, and k is the number of sets of 
inputs AND combined together. 




Another aspect of the present invention provides a conditional parallel counter having m 
possible high inputs oat of n inputs, where m<n, and n and m are integers, the counter 
comprising the parallel counter for counting inputs to generate p outputs for m inputs, 
wherein the number n of inputs to the counter is greater than 2 P , where p is an integer. 

Thus these aspects of the present invention provide a fast circuit that can be used in any 
architecture using parallel counters. The design is applicable to any type of technology 
from which the logic circuit is built. 

The parallel counter in accordance with this aspect of the present invention is generally 
applicable and can be used in a multiplication circuit that is significantly faster than 
prior art implementations. 

In accordance with another aspect of the present invention a technique for multiplying 
2N bit binary numbers comprises an array generation step in which an array of logical 
combinations between the bits of the two binary numbers is generated which is of 
reduced size compared to the prior arC 

In accordance with this aspect of the present invention, a logic circuit for multiplying 
2N bit numbers comprises array generation logic for performing the logical AND 
operation between each bit in one binary bit and each bit in the other binary number to 
generate an array of logical AND combinations comprising an array of binary values, 
and for further logically combining logically adjacent values to reduce the maximum 
depth of the array to below N bits; array reduction logic for reducing the depth of the 
array to two binary numbers; and addition logic for adding the binary values of the two 
binary numbers. 

When two binary numbers are multiplied together, as is conventional, each bit A f of the 
first binary number is logically AND combined with each bit Bj of the second number to 
generate the array which comprises a sequence of binary numbers represented by the 
logical AND combinations, A* AND Bj. The further logical combinations are carried 




out by logically combining the combinations Aj AND Bn-2, Aj AND Bn^w Ao AND Bn- 
2 , and Ao AND B N .|, where N is the number of bits in the binary numbers. In this way 
the size of the maximal column of numbers to be added together in the array is reduced. 

More specifically the array generation logic is arranged to combine the combinations Ai 
AND Bn_;> and Ao AND B n .j using exclusive OR logic to replace these combinations and 
to combine Ai AND B N -i and Ao AND B n _ 2 to replace the A> AND B n _i combination. 

In one embodiment of the present invention the array reduction logic can include at least 
one of: at least one full adder, at least one half adder, and at least one parallel counter. 
The or each parallel counter can comprise the parallel counter in accordance with the 
first aspects of the present invention. 

This aspect of the present invention provides a reduction of the maximal column length 
in the array thereby reducing the number of steps required for an-ay reduction. When the 
first aspect of the present invention is used in conjunction with the second aspect of the 
present invention, an even more efficient multiplication circuit is provided. 

Embodiments of the present invention will now be described with reference to the 
accompanying drawings, in which: 

Figure 1 is a schematic diagram of a full adder and a half adder in accordance with the 
prior art, 

Figure 2 is a schematic diagram of a parallel counter using fiill adders in accordance 
with the prior art, 

Figure 3 is a schematic diagram illustrating the logic modules executing the symmetric 
functions for the generation of binary outputs and the multiplexor (selector) used for 
selecting outputs, 

Figure 4 is a diagram illustrating the logic for implementing the symmetric function 
OR_3_l according to one embodiment of the present invention, 
Figure 5 is a diagram illustrating the logic for implementing the symmetric function 
OR_4_l according to one embodiment of the present invention. 




Figure 6 is a diagram illustrating the logic for implementing the symmetric function 
OR_5_l using 2 3 input OR gates according to one embodiment of the present 
invention, 

Figure 7 is a diagram illustrating the logic for implementing the symmetric function 
EXOR_7_l using two input exclusive OR gates according to one embodiment of the 
present invention, 

Figure 8 is a diagram illustrating the logic for implementing the symmetric function 

OR_3_2 according to one embodiment of the present invention, 

Figure 9 is a diagram illustrating the logic for implementing the symmetric function 

EXOR_5_3 according to one embodiment of the present invention. 

Figure 10 is a diagram illustrating a parallel counter using the two types of symmetric 

functions and having seven inputs and three outputs according to one embodiment of the 

present invention, 

Figure 11 is a diagram illustrating splitting of the symmetric function OR_7_2 into sub 
modules to allow the reusing of smaller logic blocks according to one embodiment of 
the present invention, 

Figure 12 is a diagram of a parallel counter using the EXOR_7_l symmetric function 
for the generation of the least significant output bit from all of the input bits, and smaller 
modules implementing symmetric functions using OR logic to generate the second and 
third output bits according to one embodiment of the present invention. 
Figure 1 3 is a another diagram of a parallel counter similar to that of Figure 1 2 accept 
that the partitioning of the inputs is chosen differently to use different functional sub 
modules according to one embodiment of the present invention, 

Figure 14 is a diagram schematically illustrating the binary tree organisation of the logic 
in a parallel counter according to a second aspect of the invention, 
Figure 15 is a diagram illustrating the logic block (Block 1) for implementing the 
elementary symmetric functions OR_2_2 and OR_2_I according to one embodiment of 
the present invention, 

Figure 16 is a diagram illustrating the logic block (Block 2) for implementing the 
secondary symmetric functions OR44, OR_4_3> OR42 and OR_4 J according to 
one embodiment of the present invention, 



Figure 17 is a diagram illustrating the logic block (Block 3) for implementing the 
tertiary symmetric functions OR_8_8, OR_8_7, OR_8_6, OR_8_S, OR_8_4, OR_8_3, 
OR_8_2 and OR_8_I according to one embodiment of the present invention, 
Figure 18 is a diagram illustrating the logic block (Block 4) for implementing the 
symmetric functions OR J 5 J 2, OR_J5_8 and OR_15_4 according to one embodiment 
of the present invention, 

Figure 19 is a diagram illustrating the logic block (Block 5) for implementing the 
elementary symmetric functions EXOR_4_2 and OR_4_l according to one embodiment 
of the present invention, 

Figure 20 is a diagram illustrating the logic block (Block 6) for implementing the 
elementary symmetric functions EXOR_15_2 and OR__15_l according to one 
embodiment of the present invention, 

Figure 21 is a diagram schematically illustrating a parallel counter using the logic blocks 
of Figures 15 to 20 according to one embodiment of the present invention, 
Figure 22 is a diagram of the steps used in the prior art for multiplication, 
Figure 23 is a schematic diagram of the process of Figure 22 in more detail, 
Figure 24 is a diagram illustrating the properties of diagonal regions in the array, 
Figure 25 is a diagram illustrating array deformation in accordance with the embodiment 
of the present invention and the subsequent steps of array reduction and adding, and 
Figure 26 is a diagram of logic used in this embodiment for array generation. 

The first aspect of the present invention will now be described. 

The first aspect of the present invention relates to a parallel counter counting the number 
of high values in a binary number. The counter has i outputs and n inputs where i is 
determined as being the integer part of Iog2 n plus 1 

A mathematical basis for the first aspect of the present invention is a theory of 
symmetric functions. We denote by G^the number of distinct k element subsets of a set 
of n elements. We consider two functions EXORnk and OR_n_k of n variables X u 
X 2 , ... X„ given by 




EXOR_nk(X*, X 2 » ... X p ) = © (X n a X»2 a ... aX*), 
OR_nJc(X,, X 2 , ... X„) = v (X n a Xa A ... AXi k ) 
where (il, i2, ... ik) runs overall possible subsets of {Xi, X2, ... X n } that contain 
precisely k elements. Blocks that produce such outputs are shown on figure 3. 

The functions EXOR_n_k and OR n k are elementary symmetric functions. Their 
values depend only on the number of high inputs among Xu X2, X3, X n . More 
precisely, if m is the number of high inputs among X|, X2, X3, . . . X n then OR_n_k(Xi, 
X 2 , ... X n ) is high if and only if m>k. Similarly, EXOR_n_k(X u X 2% ... X n ) is high if 
and only if m^k and C\ is odd. 

Although EXOR_nJc and OR_n_k look similar, OR_n_k is much faster to produce 
since EXOR-gates are slower than OR-gates. 

In the above representation n is the number of inputs and k is the size of the subset of 
inputs selected. Each set of k inputs is a unique set and the subsets comprise all 
possible subsets of the set of inputs. For example, the symmetric function OR_3_l has 
three inputs Xi, X2 and X 3 and the set si2e is 1 . Thus the sets comprise X N X2 and X3. 
Each of these sets is then logically OR combined to generated the binary output. The 
logic for performing this function is illustrated in Figure 4. 

Figure 5 illustrates the logic for performing the symmetric OR_4_* . 

When the number of inputs become large, it may not be possible to use simple logic. 

Figure 6 illustrates the use of two OR gates for implementing the symmetric function 
OR_5_l. 

Figure 7 similarly illustrates the logic for performing EXOR_7_l . The sets comprise 
the inputs Xi, X2, X3, X4, X5 ,X6, and X7. These inputs are input into three levels of 
exclusive OR gates. 



When k is greater than 1 , the inputs in a subset must be logically AND combined. 
Figure 8 illustrates logic for performing the symmetric function OR_3_2. The inputs X, 
and X 2 comprise the first set and are input to a first AND gate. The inputs X, and X 3 
constitute a second set and are input to a second AND gate. The inputs X2 and X 3 
constitute a third set and are input to a third AND gate. The output of the AND gates 
are input to an OR gate to generate the output function. 

Figure 9 is a diagram illustrating the logic for performing the symmetric function 
EXOR_5_3. To perform this function the subsets of size 3 for the set of five inputs 
comprise ten sets and ten AND gates are required. The output of the AND gates are 
input to an exclusive OR gate to generate the function. 

The specific logic to implement the symmetric functions will be technology dependent- 
Thus the logic can be designed in accordance with the technology to be used. 

In accordance with a first embodiment of the present invention the parallel counter of 
each output is generated using a symmetric function using exclusive OR logic. 

Let the parallel counter haven inputs X], X n and t+1 outputs S t , Sm, ... S 0 - So is the 
least significant bit and S t is the most significant bit. For all i from 0 to t, 

S i -EXOR_n_2 i (XwX 2 , ... X n ), 

It can thus be seen that for a seven bit input i.e. n=7, i will have values of 0, 1 and 2. 
Thus to generate the output S 0 the function will be EXOR_7_l , to generate the output S| 
the function will be EXOR_7_2 and to generate the output S 2 the function will be 
EXORJ7_4- Thus for the least significant bit the set size (k) is 1 , for the second bit the 
set size is 2 and for the most significant bit the set size is 4. Clearly the logic required 
for the more significant bits becomes more complex and thus slower to implement. 




Thus in accordance with a second embodiment of the present invention, the most 
significant output bit is generated using a symmetric function using OR logic. 

This is more practical since OR_n_k functions are faster than EXOR_nJc functions. For 
the most significant output bit 

S k -OR_n_2 , (XuX2.».X rt ). 
In particular, with a seven-bit input 

S 2 OR_7„4(X l7 X 2 , X 3 , X* Xs, X<>, X 7 ). 

Thus in this second embodiment of the present invention the most significant bit is 
generated using symmetric functions using OR logic whereas the other bits are 
generated using symmetric functions which use exclusive OR logic. 

A third embodiment will now be described in which intermediate bits are generated 
using symmetric functions using OR logic. 

An arbitrary output bit can be expressed using OR_nJc functions if one knows bits that 
are more significant. For instance, the second most significant bit is given by 

S t .! = (S t a OR_n_2 l +2 t! ) v ((^S t ) a OR_n_2 M ). 
In particular, with a seven-bit input 

Si = (S 2 a ORJ7_6(X,, X 2 , X 3 , X4, X 5 , X 6 , X 7 )) v 
((^S 2 ) a OR_7_2(X,, X 2 , X 3 , X4, X 5 , X«, X 7 )). ' 
A further reduction is 

Si = OR_7_6(X|, X 2 , X 3 , X4, X 5 , X* X 7 ) v 
((^S 2 ) a OR_7_2(X N X 2 , X 3 , X4, X 5 , X* X 7 ». 
A multiplexer MU, shown in figure 3, implements this logic. It has two inputs Xo, X u a 
control C, and an output Z determined by the formula 

Z = (C a Xi) v ((-,C) a Xo). 
It is not practical to use either EXOR_n_k functions or OR_n_k functions exclusively. It 
is optimal to use OR_n_k functions for a few most significant bits and EXOR n k 



functions for the remaining bits. The fastest, in TSMC.25, parallel counter with 7 inputs 
is shown in figure 10. 

Future technologies that have fast OR_l5_8 blocks would allow building a parallel 
counter with 1 5 inputs. A formula for the third significant bit using OR_n_m functions 
is thus: 

S t -2 = (St a Sma OR_n - 2 t +2 l " l +2 1 ^) v (S t a (^S t . t ) a OKjaJ}^) v ' 
((-.St) a Sm a OR - n_2 l - l +2 t ' 2 ) v ((-,St) a (-.S h ) a OR_n_2 1 * 2 ). 

A fourth embodiment of the present invention will now be described which divides the 
logic block implementing the symmetric function into small blocks which can be 
reused. 

An implementation of OR_7J2 is shown in figure 1 1 . The 7 inputs are split into two 
groups: five inputs from Xi to X5 and two remaining inputs X$ and X 7 . Then the 
following identity is a basis for the implementation in figure 1 1 . 

OR_7_2(Xi X 7 ) = OR_5_2(X u X 5 ) v 

(OR_5^1(X,, ... X 5 ) a OR_2_l(X 6 , X 7 )) v OR_2_2(X 6 , X 7 ) 
One can write similar formulas for OR_7_4 and OR_7_6. Indeed, 

OR_7_4(X, X 7 ) = OR_5_4(X,, .... X 5 ) v 

(OR_5_3(X u ... X 5 ) a OR„2J(X 6 , X 7 )) v 
(OR_5_2(X h X 5 ) a OR_2 2(X*, X 7 )), 

OR_7_6(X,> ...,X 7 ) = 
(OR_5_5(X if ... X s ) a OR_2_l(X 6 , X 7 )) v 
(OR_5_4(Xi, ... X 5 ) a OR_2_2(X 6 , X 7 )). 
Thus, it is advantageous to split variables and reuse smaller OR_n_k functions in a 
parallel counter. For instance* an implementation of a parallel counter based on 
partitioning seven inputs into groups of two and five is in figure 1 2. 
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Similarly, one can partition seven inputs into groups of four and three. An 
implementation of the parallel counter based oh this partition is in figure 1 3. One uses 
the following logic formulas in this implementation. 



OR_7„2(X,, X 7 ) » OR_4J2(X,, X 2 , X 3 , X4) v 
<OR_4_l(Xi, X 2 , X 5 , X4) a OR_3_l(X 5 , X^ X 7 )) v OR_3_2(X 5 , X 6 , X 7 ), 

OR_7_4(Xi, X 7 ) - OR^_4_4(X,, X 2 , X 3 , X4) v 
(OR_4_3(X l7 X 2 , X 3 , X4) a OR_3 J(X S , X* X 7 )) v 
(ORjL2(Xi, X 3? X4) a ORJ3_2(X 5 , X«, X 7 )) v 

(OR_4_l(X u X 2 , X 3 , X4) a ORJ_3(X 5 , X 6 , X 7 )X 



One needs a method to choose between the implementations in figures 1 2 and 13. Here 
is a pneumonic rule for making a choice. If one or two inputs arrive essentially later then 
one should use the implementation on figure 12 based on partition 7=5+2. Otherwise, 
the implementation on figure 13 based on partition 7==4+3 is probably optimal. 

Parallel counters with 6, 5, and 4 inputs can be implemented according to the logic for 
the seven input parallel counter. Reducing the number of inputs decreases the area 
significantly and increases the speed slightly. It is advantageous to implement a six 
input parallel counter using partitions of 6, 3 + 3 or 4 + 2. 

A preferred embodiment of the present invention will now be described with reference 
to figures 14 to 21. 

Although it is possible to implement any OR_n_k or EXORnJc function in two levels 
of logic, the fan-out of each input is very high and the fan-in of the OR gate is also very 
high. It is known that both high fan-out and high fan-in contribute significantly to the 
delay of the circuit. It is often required that more than one ORjriJc or EXOR_n k 



0R_7J>(X, x? ) = 

(OR„4_4(X u X 2 , X 3 , X4) a OR_3,2(X 5 , X^ X 7 )) v 
(OR_4_3(X|, X 2 , X h X4) a OR_3^3(X s , X 6 > X 7 )). 




function be computed from the same inputs. A two level implementation does not allow 
sharing of logic thus resulting in high area. 

This embodiment of the present invention uses the binary tree splitting of the inputs and 
the logic to reduce fan-out and enable reuse of logic. Figure 14 illustrates schematically 
the organisation of the logic. At a first level 8 elementary logic blocks 1 are used each 
having two of the binary inputs and providing 2 outputs. The elementary logic blocks 1 
of the first level perform elementary symmetric functions. These can either be exclusive 
OR symmetric functions or OR symmetric functions. At the second level four secondary 
logic blocks 2 each use the logic of two elementary logic blocks 1 and hence have four 
inputs and four outputs. The secondary logic blocks 2 perform larger symmetric 
functions. At the third level two tertiary logic blocks 3 each use the logic of two 
secondary logic blocks 2 and hence have eight inputs and eight outputs. The tertiary 
logic blocks 3 perform larger symmetric functions. At the fourth level the parallel 
counter 4 uses the logic of two tertiary logic blocks 3 and hence has sixteen inputs and 
sixteen outputs. 

As can be seen in figure 14, the binary tree arrangement of the logic enables the logic 
for performing smaller symmetric functions to be used for the parallel counter. Also the 
arrangement provides for significant logic sharing. This significantly reduces fan-out . 

As will be described in more detail, it is also possible to provide further logic sharing by 
using the elementary symmetric function logic for combining outputs of previous logic 
blocks in the binary tree. 

The functions 0R_16J5, OR_16_4 and OR_l6_l2 are constructed from the set of 
inputs Xi, X2-..X16. Although, the embodiment is described with OR_n_k functions the 
same construction applies to EXORnJc functions after replacing every OR gate by an 
EXORgate. 




The principles behind this embodiment of the invention will now be described. The 
function OR_(r+s)_t can be computed as the OR of the functions OR r_k ^RjJ-k as 
t runs through 0,l,2.:.k, 

OR_(i+s)_tpC l -X r+$ ) = v k=0 f [OR_rJc(X,...X r ) * OR^sjNkXXn-i ...X M )]. 

In an embodiment with 16 inputs, at a first level the 16 inputs are divided into 8 subsets 
~{X i,X2>, {X 3 ,X4},~.,{Xi5,Xi6}, each subset containing two inputs. For each subset a 
logic block 1 that computes OR_2_l and OR__2_2 is constructed. The 8 blocks form the 
first level of the tree. Since each input fans out into an OR gate and an AND gate we see 
that each input has a fan-out of two. Also the first layer is very regular consisting of 8 
identical blocks. The logic block 1 for computing the symmetric functions OR_2_l and 
OR_2_2 is illustrated in figure 1 5, 

At a second level, 4 logic blocks 2 are formed by combining outputs from two adjacent 
logic blocks 1 at level one. These 4 blocks comprise the second layer of the tree. Each 
block has as inputs the outputs of two adjacent blocks from level one. The inputs are 
combined to form the functions OR_4_l, OR_4J2, OR_4_3, OR_4_4. The logic block 2 
for computing these symmetric functions is illustrated in figure 16. The indices 1 and 2 
are used in the equations below to distinguish functions formed on different subsets of 
the set of inputs. The symmetric functions can be represented as: 

OR_4J = [OR_2_l], v [OR2_lfe, 
OR_4_2 = ([OR_2_l]i* [OR_2_l] 2 ) v ([OR_2_2]i+[OR_2_2] 2 ), 
ORA_3 = ([ORJ2_l)r [ORJ2_2] 2 ) v <[OR_2_2]r [OR_2J] 2 ), 
OR 4 4 - [OR_2_2] , A [OR_2_2] 2 - 

At a third level, 2 logic blocks 3 are formed by combining outputs from two adjacent 
logic blocks 2 at level two. These 2 blocks comprise the third layer of the tree. Each 
block has as inputs the outputs of two adjacent blocks from level two. The inputs are 
combined to fonn the functions ORJM, OR_8_2, OR_8_3, OR_8_4, OR_8_5, 
OR_8_6, OR_8_7 and OR_8__8. The logic block 3 for computing these symmetric 
functions is illustrated in figure 17. The symmetric functions can be represented as: 




OR_8_l = [OR_4_l]i v [OR_4_l] 2 , 
OR_8_2 = ([OR_4_l]i A [OR_4_l] 2 ) v [OR_4_2], v [OR_4_2] 2 , 
OR_8_3 = ([OR_4_l ] , A [OR_4_2] 2 ) v 
([OR_4_2], A [OR_4_lJ 2 ) v [OR_4_3), v [OR_4_3] 2 , 
OR_8_4 = ([OR_4_l], A [OR_4_3] 2 ) v ([OR_4_2]r[OR_4_2] 2 ) v 

([OR_4_3]] A [OR_4_l] 2 ) v [OR_4_4]i v [OR_4_4] 2 , 
OR_8_5 = ([OR_4_l], A [OR_4_4] 2 ) v ([OR_4_2],^[OR_4_3] 2 ) v 
([OR_4_3) , A [OR_4_2) 2 ) v ([OR_4_4] i A [OR_4_l ] 2 ), 

OR_8_6 - ([OR_4_2] , A [OR_4_4] 2 ) v 
([OR_A_3] i A [OR_4_3] 2 ) v ([OR_4_4] i A [OR_4_2] 2 ), 
OR_8_7 = ([OR_4_3]i A [OR_4_4] 2 ) v ([OR_4_4], A [OR_4_3] 2 ), 
OR_8_8 = [OR_4_4]! A [OR_4_4] 2 . 

At the final level, 3 outputs are formed by combining outputs from the two adjacent 
logic blocks 3 at level 3. This logic comprises the third layer of the tree. Outputs of the 
two adjacent blocks from level three are combined to form the functions OR_l 6_8, 
OR_16_4, and OR_16_12. The logic block 4 for computing these symmetric functions 
is illustrated in figure 1 8. The symmetric functions can be represented as: 

OR_16_4 - ([OR_8_l], A (OR_8_3] 2 ) v ([OR_8_2], A [OR_8_2] 2 ) v 

([OR_8_3], A [OR_8_l] 2 ) v [OR_8_4], v [OR_8_4] 2 , 
OR_16_8 = ([OR_8_1], A [OR_8_7] 2 ) v ([OR_8_2]i A [OR_8_6] 2 ) v 
([OR_8_3], A [OR_8_5] 2 ) v ([OR_8_4], A [OR - 8_4] 2 ) v ([OR_8_5], A [OR_8_3] 2 ) v 
([OR_8_6], A [OR_8_2] 2 ) v ([OR_8_7], A [OR_8_1] 2 ) v [OR_8_8], v [OR_8_8] 2 , 

OR_16_12 = ([OR_8_4]. A [OR_8_8] 2 ) v ([OR_8_5], A [OR^8_7] 2 ) v 
([OR_8_6], A [OR_8_6] 2 ) v ([OR_8_7], A [OR_8_5] 2 ) v ([OR_8_8]» A [OR._8_4] 2 ). 

Whilst it is possible in accordance with the invention to generate all of the outputs of the 
parallel counter using the outputs of the logic blocks 3, it is advantageous to determine 
the two least significant bits separately in parallel. This is illustrated in figures 1 9 and 




20, Although this increases fan-out slightly, it decreases the depth of the tree thus 
increases the speed of the circuit. 

Figure 19 is a diagram of a logic block 5 for determining the symmetric functions 
EXOR_4_2 and EXOR_4_L In the determination of EXOR_4_2 the faster OR gate 
replaces an EXOR gate, according to: 

EXOR__4_2 = ([OR_2_l], A [OR_2_l]2)©[OR_2_2],©[OR_2_232- 
= ([OR_2J] l A [OR_2_l] 2 ) v ([OR_2_2] 1 0[OR_J2_2] 2 y 
Four of these logic blocks 5 are provided to take the 16 inputs. Thus the logic block 5 
can be considered to be a combined level 1 and 2 implementation. 

Figure 20 is a diagram of a logic block 6 for determining the symmetric functions 
EXOR_l 5_2 and EXOR_l 5_1 which comprise the least two significant bits output 
from the parallel counter of this embodiment. This logic block comprises level 3 in the 
binary tree and it uses four of the logic blocks 5. Thus even in this parallel 
determination of the least significant two bits, there is reuse of logic using the binary 
tree structure. 

Figure 21 is a diagram of the parallel converter of this embodiment of the invention in 
which the logic of block 4 is used to determine the most significant bits and the logic of 
block 6 is used to determine the least significant bits. 

In the logic blocks illustrated in figures 16, 1 7 and 18, it can be seen that in addition to 
sharing logic for the inputs, the outputs of the elementary logic blocks, the secondary 
logic blocks and the tertiary logic blocks are input into elementaiy logic blocks thus 
providing further logic sharing. The reason for this is that OR functions are not 
independent. Assuming that k>s, 

ORj k a OR_n_s — OR_n_k, 

OR_nJc v ORjj = OR_n_s. 




These formulas result in significant reductions in logic for parallel counter. The first 
instance of such a reduction is the following formula for the second most significant bit 
of a parallel counter, 

S,-i = OR_n_(2 l +2 l! ) v [-,OR_n_2 l a OR_n_2 M ]. 
To show the second instance of such a reduction, it is assumed that k>s, 
([OR_n_k),A[OR_m_s] 2 ) v ([OR_m_s]iA [OR_n_k] 2 ) = 
[OR_m_s]|A[OR_ro_s] 2 A([OR_nJc)i v (OR_n_k] 2 )- 
These formulas allow the reduction of fan-out by sharing certain logic. As shown on 
block 2, the functions OR_4_2 and OR_4_3 are implemented by three levels of shared 
logic, 

OR_4_l = [OR_2_l], v [OR_2_l] 2 , 
OR_4_2 = ([OR_2_1],a[OR_2_1] 2 ) v [OR_2_2]i v [OR_2_2] 2 , 
OR_4_3=[OR_2_1],a[OR_2_1] 2 a([OR_2_2], v [OR_2_2] 2 ), 
OR_4_4 = [OR_2_2], A [OR_2_2] 2 . 

Block 3 is a circuit implementing logic of level three. The reductions afford the 
following expressions for functions OR_8_l, OR_8_2, OR_8_3, OR_8_4, OR_8_5, 
OR_8_6, OR_8_7, and OR_8_8, 

OR_8_l = [ORAlli v [OR_4_l] 2 , 
OR_8_2 - ([OR_4_l], A [OR_4_l] 2 ) v ([OR_4_2]i v [OR_4_2J 2 ). 
OR_8_3 = E([OR_4_l], A [OR_4_l] 2 ) A 
([OR_4_2] , v [OR_4_2] 2 )3 v [OR_4_3], v (OR_4_3] 2 , 
OR_8_4 = [([OR_4_l], A [OR_4_l] 2 ) A ([OR_4_3], v [OR_4_3] 2 )] v 

([OR_4_2] i A [OR_4_2] 2 ) v [OR_4_4], v [OR_4_4] 2 . 
OR_8_5 = [([OR_4_l], A [OR_4_l ] 2 ) A ([OR_4_4], v [OR_4_4] 2 )] v 

[([OR_4_23, A [OR_4_2] 2 ) A ([OR_4_3), v [OR_4_3] 2 )l , 
OR_8_6 = [([OR_4_2], A [OR_4„2] 2 ) A ([OR_4_4]i v [OR_4_4] 2 )] v 

([OR_4_3], A [OR_4_3] 2 ), 
OR_8_7 = ([OR_4_3], A [OR_4_3] 2 ) A 

([OR_4_4], v [OR_4_4] 2 ), 
OR_8_8 = [OR_4_4] i A [OR_4_4] 2 . 



Block 4 is a circuit implementing logic for level 4. The implementation of functions 
OR_16_8, OR_l6_4, and OR_16_12 follows reduced formulas, 

OR_16_4 = I([OR_8J],*[OR_8j] 2 ) * ([OR_8_3], v [OR_8_3J 2 )] v 

([OR_8_2], A [OR_8_2] 2 ) v [OR_8_4], v [OR_8_4] 2 , 
OR_16_8 - [<[OR_8_lJ^[OR_8_l] 2 ) * «OR_8_7], v [OR_8_7] 2 )] v 
K[OR_8_2] , A [OR_8_2] 2 ) * ([OR_8_6]i v [OR_8_6] 2 )] v 
[([OR_8_3],*(OR_8_3] 2 ) A ([OR_8_5J, v [OR_8_5] 2 )j v 
([OR_8_4], A [OR_8_4] 2 ) v [OR_8_8], v [OR„8_8] 2 . 
OR_16_l2 = [([OR_8_4], A [OR_8_4] 2 ) A ([OR_8_8], v fOR_8_8] 2 )] v 
([OR_8_6], A [OR_8_6] 2 ) v K[OR_8_5], A [OR_8_5] 2 ) * ([OR_8_7j, y [OR_8_7] 2 )J . 

The binary tree principle of this embodiment of the present invention can be 
implemented using either OR or EXOR symmetric functions. When using EXOR 
symmetric functions there is a reduction in logic which applies. Assume that k= Zi e $2' 
where S is a set of natural numbers uniquely determined by k as a set of positions of 
ones in the binary representation of k. Then 

EXOR_n_k = AND ieS EXOR_n_2 j . 
Thus, designing a circuit computing EXORnk, one gets away with computing only 
functions EXOR_n_2' on subsets and thus although EXOR logic is slower, there is less 
fan-out than when using OR logic. 

As can be seen in figure 21 , the most efficient circuit can comprise a mixture of OR and 
EXOR symmetric function logic circuits. 

During the design of the parallel counter there is also a further possibility to save logic. 
There is a useful formula, 

OR_n_k(X,...X„) = -,OR_n_(n+l-k)(- 1 X I ...-.X n ). 




Thus if a library contains a fast module generating OR_4_3 then this module can be 
used with inverters to generate OR_4_2_ The opposite observation holds as well: an 
OR 4 2 module enables the generation of OR_4_3. 

Further reductions can be applied to logic for a parallel counter based on OR elementary 
symmetric functions. For instance, the third significant bit admits the expression 
Srf = OR,nJ2 l +2 tW +2 r - 2 ) v [-^OR^J?^ 1 ) a OR - nJ2 t +2 1 " 2 )] v 
hOR_n_2 l a OR_nJ2 H +2 1 - 2 )] v [^OR_n2 M a OR_n_2 1 * 2 ]. 

Another important application of reductions is logic for a conditional parallel counter. A 
conditional parallel counter is a module with n inputs- Let Q be a subset of {0,1 ...n}. 
The subset determines a condition. The module produces the binary representation of 
the number of high inputs if this number of high inputs belongs to Q. If the number of 
high inputs does not belong to Q. the outputs can be any logical function. Such a module 
can replace a parallel counter if the number of high inputs is in Q. 

A useful conditional parallel counter has Q={0,1 -,.m} for some m<n. Logic for such a 
counter can be obtained from logic for a parallel counter with m inputs by replacing 
every OR_m_k with OR_n_k. For instance, if Q={0,I 5 2,3} then a conditional parallel 
counter has 2 outputs Si 7 So given by 

Si - OR_n_2, S 0 = EXOR_n_l . 
Another instance of a conditional parallel counter has Q={0,1,2,3 7 4,5}, 

S 2 = OR__n_4, Si = -,OR_n_4 a ORji_2 ? S 0 = EXOR_nJ. 
If the number of high inputs for one of these two counters does not belong to Q then the 
output is the binary representation of the greatest element of Q, i.e., 3=1 1 or 5=101. 

An important application of conditional parallel counters is constant multipliers. A 
constant multiplier is a module whose inputs form binary representations of two 
numbers A, B, and outputs comprise the binary representation of the product A*B 
whenever A is a number that belongs to a set of allowed constants. Since constant 
multipliers are smaller and faster then multipliers, it is beneficial to use them whenever 



one can choose one multiplicand from the set of allowed constants. One can do it, for 
instance, designing a digital filter. 

Another aspect of the present invention comprises a technique for multiplication and 
this will be described hereinafter. 

Multiplication is a fundamental operation in digital circuits. Given two n-digit binary 
numbers 

A„. I 2 n ' I +A n _ 2 2 n -V,..+A 1 2-*-Ao and B^^'+Bn^+.-.+B^+Bo, 
their product 

P 2rt . ! 2 2n - | +P 2n . 2 2 2n - 2 +, ..+P,2+P 0 
has up to 2n digits. Logical circuits generating all Pi as outputs generally follow the 
scheme in figure 14. Wallace has invented the first fast architecture for a multiplier, now 
called the Wallace-tree multiplier (Wallace, C S., A Suggestion for a Fast Multiplier. 
IEEE Trans. Electron. Comput. EC-13; 14-17 (1964)). Dadda has investigated bit 
behaviour in a multiplier (L. Dadda, Some Schemes for Parallel Multipliers, Alta Freq 
34: 349-356 (1965)). He has constructed a variety of multipliers and most multipliers 
follow Dadda' s scheme. 

Dadda 7 s multiplier uses the scheme in on figure 22. If inputs have 8 bits then 64 parallel 
AND gates generate an array shown in figure 23. The AND gate sign a is omitted for 
clarity so that A* aBj becomes AiBj. The rest of figure 23 illustrates array reduction that 
involves full adders (FA) and half adders (HA). Bits from the same column are added by 
half adders or full adders. Some groups of bits fed into a full adder are in rectangles. 
Some groups of bits fed into a half adder are in ovals. The result of array reduction is 
just two binary numbers to be added at the last step. One adds these two numbers by one 
of fast addition schemes, for instance, conditional adder or carry-look-ahead adder. 

This aspect of the present invention comprises two preferred steps: array deformation 
and array reduction using the parallel counter with the accordance with the first aspect 
of the present invention. 



The process of array deformation will now be described. 

Some parts of the multiplication array, formed by AjBj such as on figure 23, have 
interesting properties. One can write simple formulas for the sum of the bits in these 
parts. Examples of such special parts are on figure 24. In general, chose an integer k, 
and those A3j in the array such that the absolute value of i-j-k is less or equal to 1 
comprise a special part. 

Let Si be the bits of the sum of all the bits of the form AjBj shown on figure 1 . Then 

So = Ao a Bo, 
Si = (Aj a B 0 ) © (A 0 a Bi), 
S 2 = (Ai a Bj) © (Ai a B, a Ao a BoX 
S 2 k+i = (A k+! a B k ) © (A k a B k+) ) © (A k a B k a A fc .t a B k _ t ) 

for all k>0 9 
S 2k = (A k AB k )e(A k .,AB k .,A 
((A k+ i a B k .i) v (A k -i a B k -i a (Ak + ] v B k+ 0)) 
forallk>l. 

These formulas show that the logic for summing the chosen entries in the array does not 
get large. Whereas if random numbers were summed the logic for the (n + l) lh bit is 
larger than the logic for the n lh bit. 

Using these formulas, one can generate a different array. The shape of array changes. 
This is why it is called array deformation. These formulas are important because one can 
speed up a multiplication circuit by generating an array of a particular shape. 

The array in figure 25 is for an 8-bit multiplication. The AND gate sign a is omitted for 
clarity so that Aj aBj becomes AiBj< Array deformation logic generates X, Y, and Z; 

X = (A, aB 6 )©(A 0 aB 7 ), 

Y = Ai a B 7 a -.(Ao a B 6 ), 

Z = A| A B7 A Ao A 85. 



The advantage of this array over one in figure 23 is that the maximal number of bits in a 
column is smaller. The array in figure 23 has a column with 8 bits. The array on figure 
25 has 4 columns with 7 bits but none with 8 or more bits. The logic for the generation 
of X Y and Z is illustrated in figure 26. This logic can be used in parallel with the first 
two full adders (illustrated in Figure 2) in the array reduction step thus avoiding delays 
caused by additional logic. 

Array reduction is illustrated in figure 25. The first step utilizes 1 half adder, 3 full 
adders, 1 parallel counter with 4 inputs, 2 parallel counters with 5 inputs, 1 parallel 
counter with 6 inputs, and 4 parallel counters with 7 inputs. The three parallel counters 
(in columns 7, 8, and 9) have an implementation based on 7=5+2 partition. The bits X, 
Y, and 2 join the group of two in the partition. The counter in column 6 is implemented 
on 7=4+3 partition. The counter in column 5 is based on 6=3+3 partition. The remaining 
counters should not be partitioned. The locations of full adders are indicated by ovals. 
The half adder is shown by a rectangle. 

An adder for adding the final two binary numbers is designed based on arrival time of 
bits in two numbers. This gives a slight advantage but it is based on common 
knowledge, that is conditional adder and ripple-carry adder. 

Although in this embodiment the addition of two 8 bit numbers has been illustrated, the 
invention is applicable to any N bit binary number addition. For example for 1 6 bit 
addition, the array reduction will reduce the middle column height from 16 to 15 thus 
allowing two seven bit full adders to be used for the first layer to generate two 3 bit 
outputs and the left over input can be used with the other two 3 outputs as an input to a 
further seven input full adder thus allowing the addition of the 16 bits in only two layers. 

This aspect of the present invention can be used with the parallel counter of the first 
aspects of the present invention to provide a fast circuit 




Hie parallel counter of the first aspects of the present invention has other applications, 
other than used in the multiplier of one aspect of the present invention. It can be used in 
RSA and reduced area multipliers. Sometimes, it is practical to build just a fragment of 
the multiplier. This can happen when the array is too large, for instance in RSA 
algorithms where multiplicands may have more than more than 1000 bits. This 
fragment of a multiplier is then used repeatedly to reduce the array. In current 
implementations, it consists of a collection of full adders. One can use 7 input parallel 
counters followed by full adders instead. 

A parallel counter can also be used in circuits for error correction codes. One can use a 
parallel counter to produce Hamming distance. This distance is useful in digital 
communication. In particular the Hamming distance has to be computed in certain types 
of decoders, for instance, the Viterbi decoder or majority-logic decoder- 
Given two binary messages (A,, A 2 , ... A n ) and (B|, B 2 , ... B„), the Hamming distance 
between them is the number of indices i between 1 and n such that A* and Bj are 
different. This distance can be computed by a parallel counter whose n inputs are 

(Ai © Br, A 2 © B 2 , ... A n © B n ). 

The multiply-and-add operation is fundamental in digital electronics because it includes 
filtering. Given 2n binary numbers Xi, X 2 , X n . Yi» Y 2 * Y n , the result of this 
operation is 

X 1 Y 1 + X 2 Y 2 -h... + X n Y n . 
One can use the multiplier described to implement multiply-and-add in hardware. 
Another strategy can be to use the scheme in figure 22. All partial products in products 
XiYi generate an array. Then one uses the parallel counter X to reduce the array. 

In the present invention, one can use the parallel counter whenever there is a need to add 
an array of numbers. For instance, multiplying negative number in two-complement 
form, one generates a different array by either Booth recording (A. D. Booth, A Signed 



m * 

Binary Multiplication Technique, Q. J. Mech. Appl. Math. 4: 236-240 (1951)) 
another method. To obtain a product one adds this array of numbers. 



